iT邦幫忙

第 11 屆 iThome 鐵人賽

DAY 28
2
Modern Web

陣列大亂鬥系列 第 28

Day 25:Mapping And Create A New One

  • 分享至 

  • xImage
  •  

前言

開始發現,活動接近尾聲之後都已經沒有梗可以用了,雖然本來就不多。(苦笑

經天要講的內容,是關於 array 映射 (map) 這個功能。

其實在 PHP 裡面,它的細節很多,但是因為這邊只是簡單說一下,重點還是最初的匯總跟比較。

所以比較細節的部分如果有興趣,強烈建議去 PHP 官網查看喔!!


map()

這個方法在 JS 裡面的作用,就是將 array 中的每個元素丟到 calback function 中跑過一輪,之後回傳一個新的陣列。

它 callback function 中接的三個參數,分別是:值、索引、陣列。

// javascript

const ary = [1, 2, 3, 4, 5]

const result = ary.map((a, b, c) => {
    console.log(`
        a: ${a}
        b: ${b}
        c: ${c}
    `)
})

// > a: 1
// > b: 0
// > c: 1,2,3,4,5
    
// > a: 2
// > b: 1
// > c: 1,2,3,4,5
    
// > a: 3
// > b: 2
// > c: 1,2,3,4,5
    
// > a: 4
// > b: 3
// > c: 1,2,3,4,5
    
// > a: 5
// > b: 4
// > c: 1,2,3,4,5
// javascript

const ary = [1, 2, 3, 4, 5]

const result = ary.map((item) => item)
console.log(result)
// > [1, 2, 3, 4, 5]

console.log(result === ary)
// > false

此方法的調用本身不會影響到原始陣列的內容,但是,會受到 callback function 影響。

// javascript

const ary = [1, 2, 3, 4, 5]

const resultA = ary.map((item) => item * item)
console.log(resultA)
// >  [1, 4, 9, 16, 25]

console.log(ary)
// > [1, 2, 3, 4, 5]




const bry = [1, 2, 3, 4, 5]

const resultB = bry.map((item, i) => {
    bry[i] = item * item
    return bry[i]
})
console.log(resultB)
// > [1, 4, 9, 16, 25]

console.log(bry)
// > [1, 4, 9, 16, 25]

map() 的篩選範圍,在方法執行的當下就已經確定,所以後續增加的內容將不會被運行:

// javascript

const ary = [1, 2, 3, 4, 5]

const result = ary.map((item, i) => {
    ary.push(ary.length + 1)

    return item
})

console.log(result)
// > [1, 2, 3, 4, 5]

console.log(ary)
// > [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]

映射後的結果,是此方法執行到該元素時所決定的:

// javascript

const ary = [1, 2, 3, 4, 5]

const result = ary.map((item, i) => {
    ary[i + 1] = ary[i + 1] + i
    console.log(ary)

    return item / 2 
})
// > [1, 2, 3, 4, 5]
// > [1, 2, 4, 4, 5]
// > [1, 2, 4, 6, 5]
// > [1, 2, 4, 6, 8]
// > [1, 2, 4, 6, 8, NaN]

console.log(result)
// > [0.5, 1, 2, 3, 4]

console.log(ary)
// > [1, 2, 4, 6, 8, NaN]
// javascript

const ary = [1, 2, 3, 4, 5]

const result = ary.map((item, i) => {
    ary[i] = ary[i] + i
    console.log(ary)

    return item / 2 
})
// > [1, 2, 3, 4, 5]
// > [1, 3, 3, 4, 5]
// > [1, 3, 5, 4, 5]
// > [1, 3, 5, 7, 5]
// > [1, 3, 5, 7, 9]

console.log(result)
// > [0.5, 1, 1.5, 2, 2.5]

console.log(ary)
// > [1, 3, 5, 7, 9]

array_map()

PHP 的 array_map() 比較別的地方在,它可以同時傳入多個陣列。

其他部分與 JS 的 map() 作用相似。

// php

<?
    $ary = [1, 2, 3, 4, 5];

    $result = array_map(function($item) {
        return $item;
    }, $ary);
    print_r($result);
    // > Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => 5 )
?>

傳入單一陣列時,可以保留 key 值

// php

<?
    $ary = [
        'A' => 1,
        '10' => 2,
        'J' => 3,
        'E' => 4,
        '5' => 5
    ];

    $result = array_map(function($item) {
        return $item;
    }, $ary);
    print_r($result);
    // > Array ( [A] => 1 [10] => 2 [J] => 3 [E] => 4 [5] => 5 )
?>

傳入多個陣列時,key 值會被刪除

// php

<?
    $ary = [
        'A' => 1,
        '10' => 2,
        'J' => 3,
        'E' => 4,
        '5' => 5
    ];
    $bry = [
        'A' => 6,
        '10' => 7,
        'J' => 8,
        'E' => 9,
        '5' => 10
    ];

    $result = array_map(function($a, $b) {
        return [$a, $b];
    }, $ary, $bry);
    print_r($result);
    // > Array ( 
    // >    [0] => Array ( [0] => 1 [1] => 6 ) ,
    // >    [1] => Array ( [0] => 2 [1] => 7 ) ,
    // >    [2] => Array ( [0] => 3 [1] => 8 ) ,
    // >    [3] => Array ( [0] => 4 [1] => 9 ) ,
    // >    [4] => Array ( [0] => 5 [1] => 10 ) ,
    // > )
?>

如果傳入的陣列參數長度不一,會以空值填滿

// php

<?
    $ary = [
        'A' => 1,
        '10' => 2,
        'J' => 3,
        'E' => 4,
        '5' => 5
    ];
    $bry = [
        'A' => 6,
        '10' => 7,
    ];

    $result = array_map(function($a, $b) {
        return [$a, $b];
    }, $ary, $bry);
    print_r($result);
    // > Array ( 
        // > [0] => Array ( [0] => 1 [1] => 6 ),
        // > [1] => Array ( [0] => 2 [1] => 7 ),
        // > [2] => Array ( [0] => 3 [1] => ),
        // > [3] => Array ( [0] => 4 [1] => ),
        // > [4] => Array ( [0] => 5 [1] => ) 
    // > )
?>

若是將 callback 設為 NULL 可以創建多維陣列

// php

<?
    $ary = [
        'A' => 1,
        '10' => 2,
        'J' => 3,
        'E' => 4,
        '5' => 5
    ];
    $bry = [
        'A' => 6,
        '10' => 7,
        'J' => 8,
        'E' => 9,
        '5' => 10
    ];

    $result = array_map(NULL, $ary, $bry);
    print_r($result);
    // > Array ( 
    // >    [0] => Array ( [0] => 1 [1] => 6 ) ,
    // >    [1] => Array ( [0] => 2 [1] => 7 ) ,
    // >    [2] => Array ( [0] => 3 [1] => 8 ) ,
    // >    [3] => Array ( [0] => 4 [1] => 9 ) ,
    // >    [4] => Array ( [0] => 5 [1] => 10 ) ,
    // > )
?>

比較

標題\分類 JS: map() PHP: array_map()
對象 array array
參數 callback callback、array
作用陣列數量 1 1+
callback 參數 值、索引、陣列 value 值,數量與傳入陣列數相同

參考資料

以上內容將會不同步發佈在 blogger 中:第 11 屆鐵人賽系列文


大手夥伴們的專欄

歡迎大家也去訂閱一波~~

CSScoke - 金魚都能懂的這個網頁畫面怎麼切 - 金魚都能懂了你還怕學不會嗎
King Tzeng - IoT沒那麼難!新手用JavaScript入門做自己的玩具~
阿斬 - Python 程式交易 30 天新手入門
Clarence - LINE bot 好好玩 30 天玩轉 LINE API
塔塔默 - 用Python開發的網頁不能放到Github上?Lektor說可以!!
Vita Ora - 好 Js 不學嗎 !? JavaScript 入門中的入門。


上一篇
Day 24:Let Us Making A Filter
下一篇
Day 26:Concat Together
系列文
陣列大亂鬥30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

1 則留言

0
Clarence
iT邦新手 3 級 ‧ 2019-10-14 11:59:32

加油加油 ~~ 快結束了 ~
/images/emoticon/emoticon12.gif

我要留言

立即登入留言